<script>
import { h } from 'vue'
export default {
  name: 'XtxBread',
  props: {
    to: {
      type: [String, Object],
      default: ''
    }
  },
  render() {
      // 用法
      // 1. template 标签去除，单文件组件
      // 2. 返回值就是组件内容*****
      // 3. vue2.0 的h函数传参进来的，vue3.0 的h函数导入进来
      // 4. h 第一个参数 标签名字  第二个参数 标签属性对象  第三个参数 子节点
      // 需求
      // 1. 创建xtx-bread父容器
      // 2. 获取默认插槽内容
      // <i class="iconfont  icon-xiangyoujiantou"></i>
      // 3. 去除xtx-bread-item组件的i标签，因该由render函数来组织 
      // 4. 遍历插槽中的item，得到一个动态创建的节点，最后一个item不加i标签

      // 5. 把动态创建的节点渲染在xtx-bread标签中
      const list = this.$slots.default()
      const childrenNode = []
      list.forEach((item, i) => {
        childrenNode.push(item)
        if (i < list.length - 1) {
          childrenNode.push(h('i', { class: 'iconfont  icon-xiangyoujiantou' }))
        }
      });

      return h('div', { class: 'xtx-bread' }, childrenNode)
    },
}
</script>
<style  lang='less'>
.xtx-bread {
  display: flex;
  padding: 25px 10px;

  &-item {
    a {
      color: #666;
      transition: all .4s;

      &:hover {
        color: @xtxColor;
      }
    }
  }

  i {
    font-size: 12px;
    margin-left: 5px;
    margin-right: 5px;
    line-height: 22px;
  }
}
</style>